<?php
namespace Home\Controller;
use Home\Model\GoodsModel;
use Think\Cache\Driver\Redis;
use Think\Controller;
class IndexController extends Controller {
    public function index(){
        $this->display();
    }

    /**
     * model页面测试验证和自动完成
     */
    public function addGoods()
    {
        $model=new GoodsModel();
        $data['good_name']="华为p21";
        $data['good_bianma']="111111";
        $data['good_introduction']="good_introductiongood_introduction";
        $data['selling_price']="0.12";
        $data['good_type']="1";
        $data['advance_start_date']="2018-01-17";
        var_dump($model->saveData($data,1));
        $this->assign("title",'model的使用');
        $this->display();
    }

    /**
     * ajax和each方法示例
     */
    public function each_lizi()
    {
        if (IS_AJAX){
            $result=M('goods')->page(I("post.page",1),20)->select();
            sleep(3);
            $this->ajaxReturn($result);
        }
        $this->assign("title",'$.each()使用');
        $this->display();
    }

    /**
     * 把日期转换成剩余多长时间
     */
    public function datetotime()
    {
        $this->assign("title",'把日期转换成剩余多长时间');
        $this->display();
    }
    public function down_file()
    {
        $a="0731-7758259";
        echo hidtel($a);
        $phonenum = "13966778888";
        echo hidtel($phonenum);
        $this->assign("title",'下载');
        $this->display();
    }
    public function down_file1()
    {
        $re=download_file("./Public/imgs/thinkphp_5.0.12_full.zip");
        var_dump($re);
    }

    /**
     * 高并发处理--文件排他锁处理
     */
    public function file_clock()
    {
        //阻塞(等待)模式：
        $fp = fopen("lock.txt", "w+");
        if(flock($fp,LOCK_EX))
        {
            //..处理订单
            flock($fp,LOCK_UN);
        }
        fclose($fp);

        //非阻塞(等待)模式：
        $fp = fopen("lock.txt", "w+");
        if(flock($fp,LOCK_EX | LOCK_NB))
        {
            //..处理订单
            flock($fp,LOCK_UN);
        }
        else
        {
            echo "系统繁忙，请稍后再试";
        }
        fclose($fp);
        $this->assign("title",'高并发-文件排他');
        $this->display();
    }
    /**
     * 高并发处理--数据库锁处理
     */
    public function mysql_clock()
    {
        $result=D('goods')->lock(true)->where()->find();
        D('goods')->startTrans();
        if ($result['number']>0){
            //caozuo
            D('goods')->commit();//提交事务的时候同时就会释放数据库锁
        }else{
            D('goods')->rollback();
        }
        $this->assign("title",'高并发-数据锁');
        $this->display();
    }
    /**
     * 高并发处理--数据库锁处理
     */
    public function redis_use()
    {
        $redis = new Redis();
        $redis->connect('127.0.0.1', 6379);
        $redis->set("test",'测试');//设置缓存值
        echo $redis->get("test");//得到缓存值
        echo $redis->rm('test');//删除key，删除成功返回1，不成功返回0；
        echo '***'.$redis->clear();//清除缓存

        $this->assign("title",'redis使用和高并发的处理');
        $this->display();
    }
    public function ruhuo(){
        $redis = new \redis();
//        $redis = new Redis();
//        $redis->connect('127.0.0.1',6379,1);//短链接，本地host，端口为6379，超过1秒放弃链接
//        $redis->open('127.0.0.1',6379,1);//短链接(同上)
//        $redis->pconnect('127.0.0.1',6379,1);//长链接，本地host，端口为6379，超过1秒放弃链接
//        $redis->popen('127.0.0.1',6379,1);//长链接(同上)
//        $redis->auth('password');//登录验证密码，返回【true | false】
//        $redis->select(0);//选择redis库,0~15 共16个库
//        $redis->close();//释放资源
//        $redis->ping(); //检查是否还再链接,[+pong]
//        $redis->ttl('key');//查看失效时间[-1 | timestamps]
//        $redis->persist('key');//移除失效时间[ 1 | 0]
//        $redis->sort('key',[$array]);//返回或保存给定列表、集合、有序集合key中经过排序的元素，$array为参数limit等！【配合$array很强大】 [array|false]
//
//
//        /*2.共性的运算归类*/
//        $redis->expire('key',10);//设置失效时间[true | false]
//        $redis->move('key',15);//把当前库中的key移动到15库中[0|1]
//
////string
//        $redis->strlen('key');//获取当前key的长度
//        $redis->append('key','string');//把string追加到key现有的value中[追加后的个数]
//        $redis->incr('key');//自增1，如不存在key,赋值为1(只对整数有效,存储以10进制64位，redis中为str)[new_num | false]
//        $redis->incrby('key',$num);//自增$num,不存在为赋值,值需为整数[new_num | false]
//        $redis->decr('key');//自减1，[new_num | false]
//        $redis->decrby('key',$num);//自减$num，[ new_num | false]
//        $redis->setex('key',10,'value');//key=value，有效期为10秒[true]
////list
//        $redis->llen('key');//返回列表key的长度,不存在key返回0， [ len | 0]
////set
//        $redis->scard('key');//返回集合key的基数(集合中元素的数量)。[num | 0]
//        $redis->sMove('key1', 'key2', 'member');//移动，将member元素从key1集合移动到key2集合。[1 | 0]
////Zset
//        $redis->zcard('key');//返回集合key的基数(集合中元素的数量)。[num | 0]
//        $redis->zcount('key',0,-1);//返回有序集key中，score值在min和max之间(默认包括score值等于min或max)的成员。[num | 0]
////hash
//        $redis->hexists('key','field');//查看hash中是否存在field,[1 | 0]
//        $redis->hincrby('key','field',$int_num);//为哈希表key中的域field的值加上量(+|-)num,[new_num | false]
//        $redis->hlen('key');//返回哈希表key中域的数量。[ num | 0]
//
//
//
//        /*3.Server*/
//        $redis->dbSize();//返回当前库中的key的个数
//        $redis->flushAll();//清空整个redis[总true]
//        $redis->flushDB();//清空当前redis库[总true]
//        $redis->save();//同步??把数据存储到磁盘-dump.rdb[true]
//        $redis->bgsave();//异步？？把数据存储到磁盘-dump.rdb[true]
//        $redis->info();//查询当前redis的状态 [verson:2.4.5....]
//        $redis->lastSave();//上次存储时间key的时间[timestamp]
//
//        $redis->watch('key','keyn');//监视一个(或多个) key ，如果在事务执行之前这个(或这些) key 被其他命令所改动，那么事务将被打断 [true]
//        $redis->unwatch('key','keyn');//取消监视一个(或多个) key [true]
//        $redis->multi(Redis::MULTI);//开启事务，事务块内的多条命令会按照先后顺序被放进一个队列当中，最后由 EXEC 命令在一个原子时间内执行。
//        $redis->multi(Redis::PIPELINE);//开启管道，事务块内的多条命令会按照先后顺序被放进一个队列当中，最后由 EXEC 命令在一个原子时间内执行。
//        $redis->exec();//执行所有事务块内的命令，；【事务块内所有命令的返回值，按命令执行的先后顺序排列，当操作被打断时，返回空值 false】
//
//
//
//        /*4.String，键值对，创建更新同操作*/
//        $redis->setOption(Redis::OPT_PREFIX,'hf_');//设置表前缀为hf_
//        $redis->set('key',1);//设置key=aa value=1 [true]
//        $redis->mset($arr);//设置一个或多个键值[true]
//        $redis->setnx('key','value');//key=value,key存在返回false[|true]
//        $redis->get('key');//获取key [value]
//        $redis->mget($arr);//(string|arr),返回所查询键的值
//        $redis->del($key_arr);//(string|arr)删除key，支持数组批量删除【返回删除个数】
//        $redis->delete($key_str,$key2,$key3);//删除keys,[del_num]
//        $redis->getset('old_key','new_value');//先获得key的值，然后重新赋值,[old_value | false]
//
//
//
//        /*5.List栈的结构,注意表头表尾,创建更新分开操作*/
//        $redis->lpush('key','value');//增，只能将一个值value插入到列表key的表头，不存在就创建 [列表的长度 |false]
//        $redis->rpush('key','value');//增，只能将一个值value插入到列表key的表尾 [列表的长度 |false]
//        $redis->lInsert('key', Redis::AFTER, 'value', 'new_value');//增，将值value插入到列表key当中，位于值value之前或之后。[new_len | false]
//        $redis->lpushx('key','value');//增，只能将一个值value插入到列表key的表头，不存在不创建 [列表的长度 |false]
//        $redis->rpushx('key','value');//增，只能将一个值value插入到列表key的表尾，不存在不创建 [列表的长度 |false]
//        $redis->lpop('key');//删，移除并返回列表key的头元素,[被删元素 | false]
//        $redis->rpop('key');//删，移除并返回列表key的尾元素,[被删元素 | false]
//        $redis->lrem('key','value',0);//删，根据参数count的值，移除列表中与参数value相等的元素count=(0|-n表头向尾|+n表尾向头移除n个value)  [被移除的数量 | 0]
//        $redis->ltrim('key',start,end);//删，列表修剪，保留(start,end)之间的值 [true|false]
//        $redis->lset('key',index,'new_v');//改，从表头数，将列表key下标为第index的元素的值为new_v, [true | false]
//        $redis->lindex('key',index);//查，返回列表key中，下标为index的元素[value|false]
//        $redis->lrange('key',0,-1);//查，(start,stop|0,-1)返回列表key中指定区间内的元素，区间以偏移量start和stop指定。[array|false]
//
//        /*6.Set，没有重复的member，创建更新同操作*/
//        $redis->sadd('key','value1','value2','valuen');//增，改，将一个或多个member元素加入到集合key当中，已经存在于集合的member元素将被忽略。[insert_num]
//        $redis->srem('key','value1','value2','valuen');//删，移除集合key中的一个或多个member元素，不存在的member元素会被忽略 [del_num | false]
//        $redis->smembers('key');//查，返回集合key中的所有成员 [array | '']
//        $redis->sismember('key','member');//判断member元素是否是集合key的成员 [1 | 0]
//        $redis->spop('key');//删，移除并返回集合中的一个随机元素 [member | false]
//        $redis->srandmember('key');//查，返回集合中的一个随机元素 [member | false]
//        $redis->sinter('key1','key2','keyn');//查，返回所有给定集合的交集 [array | false]
//        $redis->sunion('key1','key2','keyn');//查，返回所有给定集合的并集 [array | false]
//        $redis->sdiff('key1','key2','keyn');//查，返回所有给定集合的差集 [array | false]
//
//
//        /*7.Zset，没有重复的member，有排序顺序,创建更新同操作*/
//        $redis->zAdd('key',$score1,$member1,$scoreN,$memberN);//增，改，将一个或多个member元素及其score值加入到有序集key当中。[num | 0]
//        $redis->zrem('key','member1','membern');//删，移除有序集key中的一个或多个成员，不存在的成员将被忽略。[del_num | 0]
//        $redis->zscore('key','member');//查,通过值反拿权 [num | null]
//        $redis->zrange('key',$start,$stop);//查，通过(score从小到大)【排序名次范围】拿member值，返回有序集key中，【指定区间内】的成员 [array | null]
//        $redis->zrevrange('key',$start,$stop);//查，通过(score从大到小)【排序名次范围】拿member值，返回有序集key中，【指定区间内】的成员 [array | null]
//        $redis->zrangebyscore('key',$min,$max[,$config]);//查，通过scroe权范围拿member值，返回有序集key中，指定区间内的(从小到大排)成员[array | null]
//   $redis->zrevrangebyscore('key',$max,$min[,$config]);//查，通过scroe权范围拿member值，返回有序集key中，指定区间内的(从大到小排)成员[array | null]
//   $redis->zrank('key','member');//查，通过member值查(score从小到大)排名结果中的【member排序名次】[order | null]
//   $redis->zrevrank('key','member');//查，通过member值查(score从大到小)排名结果中的【member排序名次】[order | null]
//   $redis->ZINTERSTORE();//交集
//   $redis->ZUNIONSTORE();//差集
//
///*8.Hash，表结构，创建更新同操作*/
//   $redis->hset('key','field','value');//增，改，将哈希表key中的域field的值设为value,不存在创建,存在就覆盖【1 | 0】
//   $redis->hget('key','field');//查，取值【value|false】
//   $arr = array('one'=>1,2,3);$arr2 = array('one',0,1);
//   $redis->hmset('key',$arr);//增，改，设置多值$arr为(索引|关联)数组,$arr[key]=field, [ true ]
//   $redis->hmget('key',$arr2);//查，获取指定下标的field，[$arr | false]
//   $redis->hgetall('key');//查，返回哈希表key中的所有域和值。[当key不存在时，返回一个空表]
//   $redis->hkeys('key');//查，返回哈希表key中的所有域。[当key不存在时，返回一个空表]
//   $redis->hvals('key');//查，返回哈希表key中的所有值。[当key不存在时，返回一个空表]
//   $redis->hdel('key',$arr2);//删，删除指定下标的field,不存在的域将被忽略,[num | false]
//
        $redis->connect('127.0.0.1', 6379);
        for($i = 1;$i<=1000;$i++)
            $redis->lpush('goods_list',$i);
            echo $i;
        echo '进货成功';
        $this->assign("title",'redis使用存数据进入缓存');
        $this->display();
    }
    public function redis_qianghuo(){

        $redis = new \redis();
        $redis->connect('127.0.0.1', 6379);
        //查询库存
        if($redis->lLen('goods_list') == 0)
            $this->ajaxReturn('商品已售完...');
        $uid = 1;//$_SERVER['REMOTE_PORT'];
        //查询是否购买过
        if($redis->sIsMember('bought_list',$uid))
            $this->ajaxReturn('你已经购买过了!');
        $goods_id = $redis->rpop('goods_list');
        $redis->sAdd('bought_list',$uid);
        $value = array(
            'uid'   =>  $uid,
            'goods_id'   =>  $goods_id,
            'time'  =>  time(),
        );
        $redis->hSet('order_info',$uid,json_encode($value));
        $this->ajaxReturn('购买成功。');

    }
}